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(54) Global navigation e 



e system receiver with blanked-PRN code correlation 



(57) AG NSS receiver includes a subsystem that re- 
duces the adverse effects of multipart! signals on punc- 
tual and oarly-minus-late correlation measurements by 
making the correlation measurements using a "blanked- 
PRN code." The blanked-PRN code is all zeros except 
tor adjacent positive and negative short pulses that oc- 
cur at every code bit transition In a locally-generated 
PRN code. Using the blanked-PRN code, the receiver 
makes non-zero correlation measurements only near 
the code bittransitions in the local PRN code. If the local 
PRN code and the PRN code In the received GNSS sat- 
ellite) signal are closely aligned, the non-zero correlation 
measurements are made at the times of the bit transi- 
tions in the received PRN code. The contributions to tho 
correlation measurements of the multipath signals that 



do not heve bit transitions during the adjacent positive 
and negative pulses In the blanked-PRN code cancel 
when the correlation measuromonts are accumulated - 
since these multipath signals are constant during Lho 
pulse times. The GNSS receiver includes blanked-PRN 
code logic that produces the blanked-PRN code from 
the locally-generated PRN code. The blanked-PRN 
coda logic thus produces a code that is zero-valued ex- 
cept for the adjacent pulsos. Alternatively, the blanked- 
PRN codo logic produces the zero-valued portions of 
the code by selectively disabling the blanked-code cor- 
relators in between the code bit transitions in tho local 
PRN codo. The rosult is the 6amo, namely, a system 
that produces non-zero correlation measuromonts near 
the code bit transitions in the local PRN code. 
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Description 

FIELD OF THE INVENTION 



This Invention relates generally to glc 
satellite system (GNSS) receivers and more specifically 
to GNSS receivers that reduce the adverse effects of 
muttipalh signals on correlation measurements. 

BACKGROUND OF THE INVENTION 

A GNSS receiver determinos its global position 
based on the signals it rocoivos from orbiting GPS, 
GLONASS or other satellites. Tho signal transmitted by 
each satellite is comprised of a carrier that is modulated 
by at least a binary pseudorandom (PRN) code, which 
consists of a seemingly random sequence of 1 s and Os 
that periodically repeat. The 1 s and 06 in the PRN code 
are referred to as "code chips," and the transitions in the 
code from 1 to 0 or 0 to 1 , which occur at "code chip 
times," are referred to as 'bit transitions." Each satellite 
uses a unique PRN code, and thus, a GNSS receiver 
can associate a received signal with a particular satellite 
by determining which PRN code is included in the signal. 

The GNSS receiver calculates the difference be- 
tween the time a satellite transmits its signal and the 
tims that the receiver receives the signal. The receiver 
then calculates its distance, or "pesudorange," from the 
satellite based on the associated time difference. Using 
the psoudoranges from at least four satellites, the re- 
ceiver determines its global position. 

To determine the time difference, the GNSS receiv- 
er synchronizes a locally-generated PRN code with the 
PRN code in the received signal by aligning the code 
chips In each ol the codes. It then determines how much 
the locally-generated PRN code is shifted, in time, from 
the known liming of the satellite PRN code at the time 
of transmission, and calculates the associated pseudor- 
ange. The more closely the GNSS receiver aligns the 
locally-generated PRN codo with the PRN code in tho 
recelvod signal, the more precisely tho GNSS receiver 
can determine the associated time difference and pseu- 
dorange and, in turn, Its global position. 

The codo synchronization operations include acqui- 
sition of the salellito PRN code and tracking the code. 
To acquire the PRN code, the GNSS receiver generally 
makes a series of correlation measurements that are 
separated in time by a code chip. After acquisition, the 
GNSS receiver tracks the received code. It generally 
makes "early-minus-late" correlation measurements, i. 
o., measurements of the difference between (i) a corre- 
lation measurement associated with the PRN code in 
the received signal and an early version of the locally- 
generated PRN code, and (ii) a correlation measure- 
ment associated with the PRN code in the received sig- 
nal and a lato version of the local PRN code. The GNSS 
receiver then uses the early-minus-late measurements 
In a delay lock loop (DLL), which produces an error sig- 



nal that is proportional to tho misalignment between the 
local and the received PRN codes. The error signal is 
used, in turn, to control the PRN codo generator, which 
shifts the local PRN code essentially to minimize tho 
s DLL error signal. 

Tho GNSS receiver also typically aligns the satellite 
carrier with a local carrier U6lng correlation measure- 
ments associated with a punctual version of the local 
PRN code. To do this the receiver uses a carrier tracking 
io loop. 

A GNSS receiver receives not only line-ot-sight, or 
direct path, satellite signals but also multipath signals, 
which are signals that travel along different paths and 
are reflected to the receiver from the ground, bodlos of 
« water, nearby buildings, etc. The multipath signals arrive 
at the GNSS recoiver after the direct-path signal and 
combine with the direct-path signal to produce a distort- 
ed received signal. This distortion of the received signal 
adversely affects code synchronization operations ba- 
se cause the correlation measurements, which measure 

the correlation between the local PRN code and the re- ( 
ceh/ed signal, are based on the entire received signal - 
including the multipath components thereof. The distor- 
tion may be such that the GNSS receiver attempts to 
2S synchronize to a multipath signal instead of to the direct- 
path signal. This Is particularly true for multipath signals 
that have code bit transitions that occur close to the 
times at which code bit transitions occur in the direci- 
path signal. 

so One way to more accurately synchronize the re- 
ceived and tho locally-generated PRN codes Is to use 
narrowly spaced correlators for code tracking. The use 
of the "narrow correlators" is discussed In United States 
Patents 5,101,416; 5,390,207 and 5,495,499, all of 
as which are assigned to a common assignee and incor- 
porated herein by reference. It has been determined that 
the adverse effects of multipath signal distortion on the 
early-mlnus-lato measurements is substantially re- 
ducod by narrowing the delay spacing between tho early 
40 and late versions of the PRN code. Tho delay spacing 

is narrowed such that tho noise correlates in tho oarly ( 
and lato correlation meaeuremonts. 

The narrow correlators are essentially spaced clos- 
er to a correlation peak that is associated with tho punc- 
h's tual PRN code correlation measurements than the con- 
tributions of many of the multipath signals. Accordingly, 
the early-minus-late correlation measurements mado 
by these correlators are significantly less distorted than 
they would be if they were made at a greater interval 
so around the peak. The closer the correlators are placed 
to the correlation peak, the more the adverse effects of 
the multipath signals on the correlation measurements 
are minimized. The delay epaelng can not, however, be 
made so narrow that the DLL can not lock to the satellite 
SS Prn code and then maintain code lock. Otherwise, the 
receiver cannot track the PRN code In tho received sig- 
nal without repeatedly taking the time to re-lock to the 
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SUMMARY OF THE INVENTION 



A GNSS receiver incorporating the invention further 
minimizes the adverse effects of tho multipaih signals 
on tho aarly-mlnus-laie correlation measurements, as 
well as on the punctual correlation measurements, by 
using a "blanked-PRN code." Tho blanked-PRN code is 
all zeros except for adjacent short pulsos that occur at 
overy code bit transition in the local PAN code. This 
means that-only the correlation measurements that are 
made near tho bit transitions In the local PRN code are 
non-zero. 

If the local PRN code and tho PRN code in the re- 
ceived signal are closely aligned, tho non-zero correla- 
tion measurements are made at the times of the bit tran- 
sitions In the received PRN coda. Thus, transitions in 
the received signal that are associated with the multip- 
ath signals do not contribute at all to the accumulated 
correlation measurements, unless they occur during tho 
times of the short pulses in the blanked-PRN code. Ac- * 
cordingty. the blanked-codo correlation measurements 
for the direct path signals will materially exceed those 
of the multipath signals, and the QNSS receiver will 
more closely align its local PRN code with the direct path 
signal. t 

More specifically, the blanked-PRN code includes, 
at tho times of the bit transitions in the local PRN code, 
adjacent positive and negative pulses. The two pulses, 
each of which is a small fraction of a code chip, occur 
on opposite sides of the bit transition, with the transition a 
between the two pulses occurring at the same time as 
the bit transition in the local PRN code. The adjacent 
pulses thus occur in different chip times. Accordingly, 
the non-zoro correlation measurements are made only 
for a small fraction of a chip lime, which is preferably a a 
fraction of the delay spacing associated with the narrow 
correlators. The blanked-code correlation is used once 
the code tracking delay locked loop, which uses the cor- 
relation measurements from the narrow correlators, is 
locked to the received code. Thus, the blanked-code * 
correlation can U60 the narrower code pulses without 
suffering the consequences that are associated with us- 
ing too narrow a delay spacing for tho narrow correla- 
tors. 

The Invention can be used in any GNSS receiver, * 
such as a receiver thai uses signals produced by GPS 
or GLONASS satellites. Accordingly, the invention re- 
lates to GNSS receivers, which include GPS and GLO- 
NASS receivers. 

s< 

BRIEF DESCRIPTION OF THE DRAWINGS 

Tho above and further advantages of the invention 
may be better understood by referring to the following 
description in conjunction with tho accompanying draw- si 
fngs, in which: 

Fig. 1 is a functional block diagram of a GNSS re- 



ceiver constructed in accordanco with the invontion; 
Fig. 2 is a functional block diagram of the PRN code 
correlation system included In the receiver of Fig. 1 ; 
Fig. 3 is a chart of a PRN code and associated ver- 
sions of blanked-PRN codes; 
Fig. 4 is a functional block diagram of blanked-PRN 
cod© logic that is included In tho GNSS receiver of 
Fig.i; 

Fig. 5 is a timing diagram associated with the com- 
ponents of the blanked-PRN code logic of Fig. 4; 
Fig. 6 is a flow chart of tho code tracking operations 
of the GNSS receiver of Fig. 1. 



DETAILED DESCRIPTION OF ILLUSTRATIVE 
•' EMBODIMENTS 

Referring to Fig, 1, a GNSS receiver 10 receives 
satellite signals over an antenna 11, downeonverts the 
signals In a downconverter 1 2 and samples the signals 
In a sampler 1 4 to produce I and Q signal samples in a 
known manner. The I and Q signal samples are supplied 
overa channel bus 15 to channels 16,, i6 a each of 
which is identical except for the use of a different PRN 
code for each channel. The channels are hereinafter 
collectively referred to by the reference numeral 16. 

Each channel 16 includes a PRN code generator 
20 that produces the local PRN code, and complex cor- 
relators 22 that each make I and Q correlation measure- 
ments to determine tho correlation between tho local 
PRN code and tho received signal. The correlators 22 
make the correlation measurements by multiplying the 
I and Q samples by early, punctual and/or late versions 
of the local PRN code and early, punctual and/or late 
versions of a "blanked-PRN code," which is produced 
by the blanked-PRN code logic 30. The blanked-PRN 
code is discussed below wilh reference to Fig. 3. and 
the operations of the blanked-PRN code logic 30 and 
tho correlators 22 that use the blanked-PRN code are 
discussed in more detail below with reference to Figs. 
4-5. The operations of the correlators 22 that use the 
local PRN code aro discussed below with reference to 
Fig. 2. 

Tho blanked-PRN code is used during signal track- 
ing operations, to track the received PRN code and car- 
rier. These operations occur after the GNSS receiver 1 0 
has performed its signal acquisition operations in a 
known manner, as discussed in United States Patents 
5. 1 01 .41 6; 5, 390.207 and 5, 495,499 which are incorpo- 
rated herein by reference. We discuss below the rele- 
vant operations of the GNSS receiver 1 0 in tracking the 
received code and carrier, without reference to the sig- 
nal acquisition operations. Further, we make no refer- 
ence herein to the code or carrier tracking operations 
that are unchanged by the use of the blanked-PRN 
code. For example, we do not discuss how the receiver 
determines the degree of doppler shift, or how It uses 
such information during carrier tracking operations. 
These carrier and code tracking operations, like the sig- 
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nal acquisition operations, are well known to those 
skilled in the art. Further, such carrier and code tracking 
operations are discussed in the above-referenced pat- 
ents. 

Referring still to Fig. 1 , In oach channel 1 6 the PRN 
code generator 20 is controlled by a code synchronizer 
24, which directs the PRN code generator to shift the 
local PRN code in time. The code synchronized is, in 
turn, controlled by a microprocessor 1 8 that receives the 
correlation measurements over a control bus 21 . The 
microprocessor 18 uses the correlation measurements 
in a delay locked loop (DLL) that the processor operates 
for the channel. The DLL producos, in a known mennor, 
a code-tracking error signal that the code synchronizer 
uses to direct the PRN code generator 20 to shift the 
local PRN code. The code synchronizer essentially di- 
rects the PRN code generator to shift the local PRN 
code so as to minimize the code-tracking error signal. 

A carrier synchronizer 26 operating in a known 
manner aligns a locally-generated carrier to the satellite i 
carrier. The carrier synchronizer 26 Is controlled by the 
microprocessor 18, which produces a carrier phase er- 
ror signal based on the correlation measurements as- 
sociated with the punctual version of the local PRN 
code. The carrier synchronizer then controls the angle i 
by which the l and Q signal samples are rotated by the 
correlators 22, to reduce the carrier phase error and re- 
move the satellite carrier from the samples. The carrier 
synchronizer 26 also In a known manner providos infor- 
mation to tho code synchronizer 24 for carrier-aiding the a 
tracking of the received PRN code. 

Based in part on the calculated carrier phase and 
tho timing oi the local PRN code, the microprocessor 18 
performs the pseudorange calculations and determines 
the global position of the receiver, all in a known manner, a 

Referring now to Fig. 2, the code synchronizer 24 
sends early, punctual and late clock signals to the PRN 
code generator 20 and delays 28 and 29, respectively. 
Tho PRN code generator 20 produces the early version 
of the PRN code. The delay 26 producos tho punctual « 
version of lhe PRN code, in rosponse to the receipt of 
the early version of the code from the PRN code gener- 
ator 20 and the punctual clock signal from the code syn- 
chronizer 24. Similarly, the delay 29 produces the late 
version of the PRN code, in response to the receipt of 41 
the punctual version of the code from the delay 28 and 
the late clock signal from the code synchronizer 24. 

The complex correlator 22a receives the punctual 
version of tho PRN code and tho I and Q samples of the 
received signal, as well as carrier angle Information from so 
the carrier synchronizer 24. It then multiplies the signal 
samples by the code, after the signal samples have 
been rotated by the carrier angle, to romove the carrier. 
Alternatively, the correlator 22a removes the carrier af- 
ter the PRN code multiplication. The results of the rota- ss 
tion and multiplication operations, i.e., the punctual cor- 
relation measurements, are accumulated for a prede- 
termined time before they are sent to the microproces- 



sor 1 S over control bus 21 . The microprocessor 18 uses 
tho correlation measurements in a phase locked loop, 
to determine a carrier phase error and sends to the car- 
rier synchronizer 26 signals associated with the error 
5 signal. The carrier synchronizer 26 then adjusts the an- 
gle by which It directs the correlators 22a-b to rotate the 
I and Q samples. 

The complex correlaior22b is configured to perform 
in either of two modes, namely, a signal acquisition 
9 mode and a signal tracking mode, as is discussed in 
more detail in the above-referoneed patents. In the sig- 
nal acquisition mode, a switch 25 is set to a first position 
In which it continuously asserts an enable line 27b. and 
thus, continuously enables the correlator 22b. In this 
> mode, the correlator 22b makes correlation measure- 
ments associated with thB early version of tho local PRN 
code. After the signal is acquired, the switch 25 is set in 
a second position In which lhe enable line 27b is selec- 
tively asserted by an XOR gate 28. In this second, or 
1 6ignal tracking, mode the correlator22b produces early- 
minus-late correlation measurements that are used in 
code tracking operations. The XOR gate 23 asserts the 
enable line when the early and late versions oi the PRN 
codes differ, and de-assorts the enable lino when the 
two versions are the same. The correlation measure- 
ments produced by the correlator 22b are tho same as 
those produced by subtracting correlation measure- 
ments produced by separate early and late correlators. 

When the correlator 22b is enabled It rotates the re- 
ceived signal samples to remove the carrier and multi- 
plies the rotated samples by the early version of the PRN 
code. Alternatively, the correlator 22b may Instead mul- 
tiply the samples by the late version of the code. Further, 
the correlator 22b may rotate the samples to remove the 
carrier after the multiplication operation. The correlator 
22b next accumulates tho results of the multiplication 
and rotation operations, that is, it accumulates tho early- 
minus-late correlation measurements. It thon, after a 
predetermined period of time, forwards the accumulated 
measurements to the microprocessor 18 over the con- 
trol bus 21. Tho microprocessor thon usee tho correla- 
tion measurements in its DLL processing operations. 

At the start of the code tracking operations, the code 
synchronizer 24 adjusts the delay spacing between the 
early, punctual and late versions of the PRN code by 
adjusting the timing of the early, punctual and late clock 
signals. The delay spacing is set to one code chip for 
signal acquisition and narrowed to a fraction of a code 
chip for code tracking, as discussed in the above-refer- 
enced patonts. The correlaior(s) that are operating with 
the early and late versions of the PRN code that are sep- 
arated in time by the narrowed delay spacing are what 
is referred to in the GNSS industry as the "narrow cor- 
relators." 

As discussed above, the early-minus-late correla- 
tion measurements produced by the correlator 22b are 
used by the microprocessor 18 in the DLL processing 
operations that control the operations of the code syn- 
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chronlzor 24 immediately after thg satellite signal has 
been acquired. Accordingly, the delay spacing associ- 
ated with these correlators, that is, the narrowed delay 
6paclng, should not be made too narrow, lo ensure that 
the DLL locks to the received code. This is particularly 
truofor GNSS receivers that are stationed in moving ve- 
hicles, such as automobiles, planes and so forth. The 
llmll of the delay spacing is ulllmalely controlled by the 
front-end or RF bandwidth of the receiver. Using a wider 
bandwidth, the delay spacing can be made narrower, as 
discussed in the above-referencod patents. It is our ex- 
perience that wllh a front-end bandwidth of 10 MHz, the 
delay spacing can bo narrowed to approximately ono 
tenth of a code chip. 

In addition to the correlators 22a-b that produce the 
code tracking correlation measurements, the receivor 
10 uses punctual and early-minus-late "blanked-code* 
complex correlators 22e and 22d. to make correlation 
measurements using early, punctual and late versions 
of a blanked-PRN code. These blanked-code correla- 
tors correlate the I and Q signal samples with a code 
that is all-zeros except for a fraction of a code chip that 
corresponds to the times of the bit transitions in the local 
PRN code, as discussed below with reference to Figs 
3-4. 

Using the blanked-PRN code eliminates contribu- 
tions to the accumulated punctual and early-minus-late 
correction measurements for all of the multipath signals, 
except those that have bit transitions that correspond In 
time to the non-zero portions of tho blanked-PRN code. 
The contributions to the correlation measurements 
made by the multipath signals that do not have transi- 
tions at the times of tho blanked-code pulses cancel 
when the non-zero correlation measurements are accu- 
mulated. Specifically, those multipath signals are essen- 
tially constant during the limes of the ad|acent positive 
and negative pulses in the blanked code. To lake the 
correlation measurements, the signals are multiplied by 
the positive (+1) and the negative (-1) code values as- 
sociated with the adjacent code pulses. When the re- 
sults aro accumulated, or summed, the contributions of 
the multipath signals cancel. 

Referring now to Fig, 3, we explain the theory be- 
hind the use of the blanked-PRN code. We then explain 
with reference to Figs. 4 and 5 how the GNSS receiver ' 
10 takes advantage ol blanked-PRN code correlation. 

Referring now to Fig. 3, the local PRN code is de- 
noted by A. the blanked-PRN code is denoted by B, the 
early-mlnus-late version of the blanked-PRN code Is de- 
noted by C and the received satellite signal is denoted t 
by D. As shown, the local PRN code makes a positive 
bit transition 400 to +1 at code chip time t, , followed by 
a negative bit transition 402 to -1 at code chip time £ 
and a positive bit transition 404 to at code chip time 
t 3 . At code chip time i 4 thora is no bit transition in the £ 
code. At code chip time t B tho local PRN code makes a 
negative bit transition 406 from 1 to -1, stays at -1 
through code chip timo ts and then makes a positive bit 



transition 408 from -1 to 1 at time t 7 , and a negative tran- 
sition 41 0 at code chip time t e . 

The blanked-PRN code is zero-valued between bit 
transHions in the local PRN code, and includes at the 

s times of tho bit transitions In the local PRN cede coupled 
short pulses 420. The pulses 420 Include a first pulse 
421 thatprecedes the blttransitlonlnihe local PRNcode 
and a second pulse 422 lhat tallows the bit transition. 
As shown in the drawing, the blanked-PRN code in- 

10 eludes at the tines of each positive bit transition 400, 
404, and 408 a positive first pulse 421 followed by a neg- 
ative second pulse 422. and at tho times of each nega- 
tive bit transition 402, 406 a nogative first pulse 421 fol- 
lowed by a positive second pulse 422. 

15 The blanked-PRN coda may instead include a neg- 
ative first pulse and a positive second pulse at the pos- 
itive bit transitions In the local PRN code, as long as the 
opposite polarity pulses occur at the negative bit transi- 
tions. The effect of using theso different polarity puleea 
20 is a sign change in the slope of an associated discrimi- 
nator curve. 

The received satellite signal includes, in the dlroct- 
path contribution to the signal, code bit transitions 450. 
As discussed above, the local PRN code is tracking the 
25 direct-path PRN code using the narrow correlators, and 
thus, the bit transitions 400-408 in the local PRN code 
occur close to the bit transitions 450 In the direct-path 
PRN code. The received signal also Includes muftipalh 
signal contributions, which have bit transitions 452 and 
no 454. The received signal is thus a combination of the 
signals labeled ^direct-path and D MULT1PATH in Fig. 3. 

To determine 1he correlation between tho received 
satellite signal and the blanked-PRN code, the correla- 
tors 22c-d multiply me satellite signal, or more precisely 
3S samples of that signal, by the blanked-PRN code. Ac- 
cordingly, when iho multiplication involves the zero-val- 
ued portion of the blanked-PRN code, the correlation 
measurements are all zeros, and thus, they do not con- 
tribute to the accumulated correlation measurements. 
to The bit transitions 4SO in the direct path signal occur 
close to the bit transitions 400-40B in the local PRN 
code. The edges of the bit transitions 4S0 thus occur at 
times that correspond to the pulses 420 In the blanked- 
PRN code. Accordingly, the blanked-code correlators 
« 22c-d make non-zero correlation measurements asso- 
ciated with these bit transitions 450. These non-zero- 
correlation measurements contribute to the accumulat- 
ed correlation measurements that aro passed to the 
code and carrier synchronizers. 
0 The bit transHions 452 in the received signal that 
are associated with short-range multipath signals, and 
the bit transitions 454 are associated with long-range 
multipath signals. The blanked-code correlators 22c-d 
make zero-valued correlation measurements assoclat- 
* ed with the bit transitions 452 and 454 that occur during 
the zero-valued portions of Ihe blanked-PRN code. Fur- 
ther, the contributions of these multipath signals to the 
non-zero correlation measurements cancel if no bit tran- 
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sltions 452 or 454 occur during the non-zero portion of 
the blanked-PRN coda. The contributions from the mul- 
tipath signals, which are constant throughout the dura- 
tion of the pulses, cancel because the same value Is 
multiplied by, for example, a first positive pulse in the 
blanked-PRN code and an adjacent negative pulse in 
the blanked-PRN code. When these products are accu- 
mulated, Iho portions of the correlation measurements 
attributable to tho multipath signals add to zero. The por- 
tions of the correlation measurements attributable to 
signals with bit transitions that occur during the pulse 
times do not. however, accumulate to zero. Accordingly, 
the multipath signals with bit transitions that occur dur- 
ing tho pulse times do contribute to the correlation 
measurements. 

As long as at least 6ome of the bit transitions in the 
multipath signals occur before pulse 421 or after pulse 
422, the blanked-coda correlators 22c-d produce accu- 
mulated correlation measurements for multipath signals 
that are lower than those associated with the direct-path 
signal. For the direct path signal, the correlators accu- 
mulate non-zero correlation measurements in which tho 
contributions of the signal do not cancel. For the multi- 
path signals, the correlators accumulate non-zero cor- 
relation measurements in which the contributions from 
all of the multipath signals except those with bit transi- 
tions that occur during the code pulses cancel. Accord- 
ingly, the receiver will not track the multipath signals that 
have bit transitions that occur at times other than the 
times of the short adjacent pulses. 

The early-minus-late blanked-PRN code is a com- 
bination ot an early blanked-PRN code and a negated 
late blanked-PRN code. It is zero-valued between bit 
transitions In the local PRN code and Includes at each 
bit transition In tho local PRN code a series of three puls- 
es 470. For positive bit transitions in the local PRN code, 
the early-minus-laie blanked-PRN code Includes (i) a 
positive first pulse 471 that precedes the positive pulse 
421 In the blanked-PRN codo, (ii) a negative socond 
pulso 472 that is twico as long as the positive first pulse 
and corresponds in tlmo to the coupled pulsos 420 in 
the blanked-PRN code, and (iii) a positive third pulse 
473 that follows the negatlvo pulce 422 in the blanked- 
PRN code. For negative bit transitions in the local PRN 
code, the polarities of the pulses 471 -473 are the oppo- 
site of those of the pulses 470 associated with the pos- 
itive bit transitions. 

The polarities of the series of pulse6 470 may be 
reversed, such that, for example, the pulses associated 
with a positivo bit transition in tho local PRN code consist 
of a negative first pulse, a positive second pulse and a 
negative third pulse. As discussed above with respect 
to the blanked-PRN code, the consequence of reversing 
the polarities of the pulses is a sign change in the slope 
of an associated discriminator curve. 

Referring also to Fig. 4, the blanked-PRN code logic 
30 Includes four delays 32-35, namely, two early delays 
32-33 and two late delays 34-35. The PRN code genor- 
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ator 20 producos the earliest version ol the local PRN 
code, labeled E2 in the drawing. After passing through 
delay 32, an early version of the local PRN code is pro- 
duced that ie closer in time to the punctual PRN code. 
* This early version of the code Is labeled E1 In the draw- 
ing. The delay 33 produces the punctual version of the 
local PRN code, which corresponds to the punctual ver- 
sion of the code produced by delay 28 (Fig. 2). The dolay 
34 produces a late version of the code, which is labeled 
'0 L1 in the drawing. A later version of the code, which is 
labeled L2, is produced by the delay 35. The delays 
32-35 are spaced from one anothor by a time A, which 
is aleo tho duration of tho short pulso 421 or 422. The 
earliest and latest delays 32 and 35 are preferably 
s spaced by a fraction of a code chip that is less than the 
delay spacing associated with tho narrow correlators 
22a-b (Fig 2). 

The blanked-PRN code logic 30 includes two XOR 
galos 500 and 502, respectively, that control tho enable 
so lines 27c and 27d of the blanked-coda correlators 22c 

and 22d. The correlators 22c-d are disabled during the ( ) 
zero-valued portions of the associated punctual and 
oarly-minus-lato blanked-PRN codes and enabled, re- 
spectively, during the pulsos 420 or 470. This produces 
25 the same result as multiplying the I and Q samples of 
the satellite signal by tho zero-valued and non-zero val- 
ued portions of the codes, namely, making no changes 
or contributions to the accumulated correlation meas- 
urements during the zero-value portions of the blanked- 
& PRN code and making contributions during the non-zero 
valued portions of the code. 

The XOR gates 500 and 502 work in conjunction 
with the gates 504-507 and Inverter 508 to produce at 
the correlators 22c-d the putees 420 and 470. Since the 
35 correlators do not respond to the code signals they re- 
ceive while they are disabled, the gates 504-507 need 
not and indeed do not produce zero-valued signals for 
the periods during which the correlators are disabled. 
Alternatively, the blanked-PRN code logic 30 could per- 
40 manently enable the correlators 22c-d, and produce di- 
rectly tho non-zoro and zero-valuod portions of tho ( ' 
blanked codes. 

The blanked-PRN code, labeled B In Figs. 3 and 5, 
is produced at tho correlator 22c by enabling the corre- 
<S lator whenever the versions E1 and L1 of the local PRN 
code differ. These versions differ whenever there is 
about to be a bit transition in the punctual version of the 
local PRN code. 

Referring now also to Fig. 5, the El code goos from 
so low to high at time t, -A, which Is just before the punctual 
PRN code makes the positive bit transition 400 at time 
i,. At this time VA, tho XOR gate 500 asserts line 27c, 
to enable tho correlator 22c. The local punctual PRN 
code is low at this time and an inverter 508, which pro- 
ss duces the blanked-PRN code on line 37. produces a 
high signal. At time t„ the punctual version of the PRN 
code makes a positive transition and the signal pro- 
duced by the inverter 508 transitions to low. The inverter 
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508 has thus far produced on line 37 the positive first 
pulse 421 and a transition to the negative second pulse 
422. 

Continuing for a lime A through the delay 34. the 
Inverter 508 produces tho low Blgnal and the XOfl gate 
500 holds the onable line 27c high. At time i,+A, the L1 
version of the local PRN code makes a positive transi- 
tion and the XOR gaie 500, which now receives two- 
positivo signals, do-asserts line 27c and disables the 
correlator 22c. This produces at the correlator 22c the 
transition to zero that ends the pulse 422. The XOR gate 
500 then continues to hold the line 27e low until tho E1 
signal transitions from high to low at a time tj-A, which 
ie juei before a next bit transition in tho punctual version 
of tho local PRN code occurs at time tj. The inverter 508 
produces a non-zero signal when the correlator 22c is 
disabled. However, since the correlator 22c does not, 
when it is disabled, respond to the inverter output signal, 
that signal is in effect zero-valued at the correlator. 



spectively, high and low signals. The NOR gate 507 re- 
sponds to the signals produced by the AND gates by 
producing on line 38 a low signal, which is the transition 
beiween the positive first pulse 471 and the negative 
second pulse 472. The gates 504-507 continue to pro- 
duce the same signals for a period of 2a, until the L1 
version of the code makes a positive transition. When 
this occurs at lime 1,+A, the XOR gale 504 produces a 
tow signal and the AND gates 505 and 506 each pro- 
duce low signals. Tho NOR gate 507 then produces a 
high output signal, which is The transition from the sec- 
ond pulse 472 to the third pulse 473. 

At a tlmo A later, i.o., at time t 1+ 2A. ihe L2 signal 
goes high, and the XOR gata 502 do-aeeerte lino 27d 
and dlsablos the correlator 22d. This produces at the 
correlator the transition to the zero-valued portion of the 
early-mlnus-late blanked-PRN code that follows the 
pulso 473. The XOR gate 502 then keeps the correlator 
22d disabled until a time 2A before a next bit transition 



When the correlator 22c is enabled, it responds to 20 In lne punctua , PRN code , n the exampl9i , he XOR t 

first and second nil affle 491 anH AOO h„ nM .h -1 .. ..... ^ 



the first and second pulses 421 and 422 by producing 
non-zero correlation measurements. It thus multiplies 
the I and Q samples of the received signal by ±1, de- 
pending on the polarity of the individual pulses 421 and 
422, and accumulates the results. The correlator 22c Is 
disabled at all other times, and thus, does not during 
these times make any contributions to the accumulated 
correlation measurements. This Is tho same result that 
would occur If the correlator Instead multiplied the I and 
Q samples by both the non-zero and the zero-valued 
portions of the blanked-PRN code and accum ulated cor- 
relation measurements. 

The early-minus-late blanked-PRN code, which is 
denoted C In the Figs. 3 and 5. Is produced at correlator 
22d by XOR gate 502 and NOR gate 507. Whenever 
the E2 and L2 versions of the local PRN code differ, the 
XOR gate 502 asserts the line 27d, and thus, enables 
the correlator 22d. This occurs at a time t r 2A. which Is 
a time 2a before a bit transition in the punctual vorsion 
of tho PRN code, for example, at time t,. 

When tho XOR gate 502 produces the high signal 
at time t,-2A, E2 is high and E1, Li and L2 are all low. 
The XOR gate 504, which receives tho El and L1 ver- 
sions of tho code, produces a low signal that is applied 
to one input of (he AND gate 506. The AND gate 506 
also receives the E2 version of the coda, and produces 
a low signal in response to the high E2 signal and the 
low signal from the XOR gate 504. The AND gate 505 
similarly produces a low signal in response to receiving 
inverted versions of the E2 signal and the signal from 
the XOR gate 504. The NOR gate 507 receives these 
two low signals and produces on line 38 a high output 
signal, which Is the start of the positive first pulse 471 In 
tho early-minus-late blanked-PRN code. 

The XOR gat© 504 continues to produce a low sig- 
nal until the E1 version of the local PRN code goes high 
at a time 1-,-A. At this time the XOR gate 504 produces 
a high signal and AND gates 505 and 506 produce, re- 



502 enables the correlator 22d before tho bit transitions 
at times t 2 , tg, t 5 and so forth. It does not, however, en- 
able the correlator at times t« or tg, since the local PRN 
codo does not make bit transitions at these times. 

The correlator 22d responds to the pulses 471 -473 
that are associated with the bit transition 400 by produc- 
ing non-zero correlation measurements that correspond 
to multiplying the I and Q samples of the received signal 
by +1 , -1 and +1 , respectively. The correlator 22d is then 
disabled until shortly before a next bit transition In punc- 
tual PRN code. It thus produces no further correlation 
measurements until time t 2 -2A. As discussed above, the 
disabling of the correlator between bit transitions in the 
local prn code produces the same result as multiplying 
the I and Q samples by the zero-valued portions of the 
early-minus-late blanked PRN codo, and accumulating 
the zero-valued correlation measurements. 

The two AND gates 504, 506 may bo replaced with 
a multiplexer (not shown) that selects the E2 signal or 
an inverted E2 signal, depending on the state of the sig- 
nal produced by the XOR gate 502. 

The minimum width of the pulee 421 or 422 ie con- 
trolled by the front-end or RF bandwidth of the receiver. 
Tho pulses must be wide enough to capture the rising 
or falling edges or the bit transitions in the received sig- 
nal. With a wider front-end bandwidth, tho edges of the 
bit transitions rise and fall more sharply. The edgos can 
thus be captured with a pulse of shorter duration. Con- 
versely, with a narrower front end bandwidth and less 
sharp bit transition edges, pulses of longer duration are 
required. If the receiver has a front-end bandwidth of 1 0 
MHz, the duration of the pulse 421 or 422 is 0.5 micro- 
seconds or one twentieth of a code chip. 

Referring now also to Fig. 6, we discuss the opera- 
tions of the GNSS receiver 10. The GNSS receiver ac- 
quires the satellite signal, and narrows the delay spac- 
ing between code-tracking correlators 22a-b to track the 
satellite PRN code using a code-tracking DLL (steps 
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600-601 ), When the code tracking DLL is locked to the 
received PRN code, the GNSS receiver uses the corre- 
lation measurements from the blanked-code correlators 
in a blanked-code DLL, to more closely align the local 
PRN code with the satellite PRN code (steps 602. £ 
605-606). It also uses the blanked-PRN coda punctual 
correlation measurements to align the local carrier with 
the satellite carrier (step 607). The receiver at the same 
time continues to track the received PRN code wlih the 
code-tracking correlators, in order to keep the code- 10 
tracking DLL locked to the received code. If the code 
tracking DLL loses code lock, the receiver uses the nar- 
row correlator and punctual PRN code correlation 
measurements to re-lock to the code In the received elg- 
nal. While the code tracking DLL i6 re-locking, the re- 
ceiver uses theso correlation measurements to re-align 
the local PRN coda and carrier with the satellite PRN 
code and carrier (steps 602-604). Once the code track- 
ing DLL is again locked to the received code, the receiv- 
er again uses the blanked-PRN coda correlation meas- so 
urements. (steps 602, 605-607). 

Using either the PRN code or blanked-PRN codo 
correlation measurements to align the carriers and PRN 
codes, the receiver determines the psoudoranges, 
based In part on the timing of the local PRN coda, and ss 
the calculated carrier phase angle and phase angle 
tracking error (step 608). 

If the GNSS receiver 1 0 Is stationary, it may uso the 
code tracking correlators for both the narrow and the 
blanked-code correlation. As long as the bit transitions so 
in the received code occur when they are expected ■ 
which is at the times of the pulses in the blanked-PRN 
code -the blanked-code DLL will track Che received 
codo. if the transitions In the received code do not occur 
at the expected times, the DLL will lose code lock and as 
the receiver must re-lock to the received code using the 
narrow-correlator delay spacing, before it can again 
make the blanked-code correlation measurements. 

The GNSS receiver 10 eliminates from Its correla- 
tion measurements essentially all contributions from the *o 
muhipath signals by correlating the received signal with 
the early, punctual and late version of the blanked-PRN 
codo. The GNSS receiver 10 thus more accurately 
aligns the local PRN code and carrlor with the direct- 
path code and the carrier in the received signal, and da- *s 
termlnes more precise pseudorangos based on the 
more accurate PRN codo timing and carrier phase angle 
information. Since the blanked-codo correlation is used 
only after the receiver i6 already tracking the received 
PRN code with the narrow correlators, that is. after the so 
local and the received PRN codes are closely aligned, 
the delay spacing associated with the blanked-codo cor- 
relation may be set essentially as narrow a6 the front- 
end bandwidth allows. 

The foregoing description has been limited to a epe- ss 
cifio embodiment of this invention. It will be apparent, 
however, thai variations and modifications may be made 
to the invention, with the attainment of some or all of its 
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advantages. Therefore, it is the object of the appended 
claims to cover all such variations and modifications as 
come within the true spirit and scope of the invention. 



Claims 

1 . A GNSS receiver including; 

A. moans for acquiring a GNSS satellite signal; 

B. means fortraeklng a PRN code In the GNSS 
satellite signal; 

C. blanked-codo correlation moans for making 
correlation measurements using a blanked- 
PRN code, to closoly align a locally-generated 
PRN codo to the PRN code in the GNSS satel- 
lite signal. 

2. The GNSS receiver of claim 1 wherein tho blanked- 
codo correlation means includes blanked-codo 
generation means for producing the blankod-PRN ( ) 
code, which has non-zero pulses that correspond 
in time to bit transitions In tho locally-generated 
PRN code and is otherwise zero. 

3. The GNSS receiver of claim 1 wherein the blanked- 
code correlation means makes non-zero correlation 
measurements at times that correspond to bit tran- 
sitions in the locally-generated PRN code and zero- 
valued correlation measurements otherwise. 

4. The GNSS receiver of claim 1 wherein the blanked- 
code correlation means makes correlation meas- 
urements at times that correspond to bit transitions 
In the locally-generated PRN code and refrains from 
making correlation measurements otherwise. 

5. The GNSS receiver of claim 2, wherein the blanked- 
code generation means produces at each positive 
bit transition In the locally-generatod PRN code a 
short positive pulso at a time that precodos the bit ( % 
transition and a short negative pulse at a timo that 
follows the bit transition, with a transition between 
the positive and negative pulses occurring at the 
same time as the bit transition in the loeally-goner- 
ated PRN codo, and produces pulses of reverse po- 
larity at times that precede follow negative bit tran- 
sitions in the locally-generated PRN code. 

6. The GNSS race Ivor of claim 2, wherein tho blanked- 
code generation means produces at each negative 
bit transition in the locally-generated PRN code a 
short positive pulse at a time that precedes the bit 
transition and a short negative pulse at a time that 
follows the bit transition, with a transition between 
tho positive and negative pulses occurring at the 
same time as the bit transition In the locally-gener- 
ated PRN code, and produces pulses of reverse po- 
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larity at times lhat precede follow positive bit tran- 
sitions in the locally-generated PRN code. 

7. The GNSS receiverol claim 2. wherein the blanked- 
code generation means Includes: 

a. means Tor producing a code thai transitions 
from positive to negative at each positive bit 
transition In the locally-generated PRN code 
and from negative to positive at each negative 
bit transition in the locally-generated PRN 
code; and 

b. means for selectively enabling blanked-codo 
correlators at times that precede the bit transi- 
tions in the Jocally-gonorated PRN code and 
disabling tho blanked-code correlators at times 
that follow the bit transitions in the locally-gen- 
erated PRN code. 

8. The GNSS receiver of claim 7 wherein ; 

c. the blanked-PRN codo generation means 
further includes means for producing an early- 
minus-late blanked-PRN code, and 

d. the means for selectively enabling the J 
blanked-codo correlators further enables an 
early-minus-late blanked-code correlator at 
times that precede the bit transitions in the lo- 
cally-generated PRN code and disables the 
early-minus-late blanked-code correlator at £ 
times thatfollowthe bit transitions in the loeally- 
generated PRN code. 

9. The GNSS receiver of olalm 8 wherein the blanked- 
PRN code generation means produces early and s 
late version of (he locally-generated PRN code that 
are closely spaced in time and produces the pulses 

at the times during which the early and late versions 
of the locally-generated PRN code differ. 

4 

10. Tho GNSS receiver of claim 9 whoroin the blanked- 
PRN code generation means produces a pulse that 
precedes the bit transition in the locally-generatod 
PRN code by starting a first pulse at the time the 
early version of the locally-generated PRN code * 
makes a bit transition and transitioning to a second 
pulse, which follows tho bit transition in the locally- 
generated PRN code, at the time that the locally- 
generated PRN code makes tho corresponding bit 
transition. si 

11. The GNSS receiver of claim 10 wherein the means 
for selectively enabling the blanked-code correla- 
tions enables the correlators at th e time that the ear- 
ly version of the locally-generated PRN code makes si 
a bit transition and disables the correlators at the 
time the late version of the locally-generated PRN 
code makes a corresponding bit transition. 



12- The GNSS receiver of claim 11 wherein the 
blankod-PRN code generation means further pro- 
duces earlier and later versions of the locally-gen- 
erated PRN code that are closely spaced In time 
s and produces the pulses at the times during which 
tho earlier and laler versions of the locally-generat- 
ed PRN codo differ. 

13. The GNSS receiver of claim 12 wherein tho 
o blanked-PRN code generation means produces an 

early-mlnus-lato blanked-PRN code that includes a 
first pulse thai precedes the bit transition in the lo- 
cally-generated PRN code, a second pulse that 
straddles the bit transition in the locally-generated 

s code and a third pulse that follows the bit transition 
in tho locally-generated code, tho blanked-PRN 
code generation means starting the first pulse atlhe 
time the earliest version of the locally-generated 
PRN code makes a bit transition, transitions to the 

o second pulse at the time that the early version of 
tho locally-generated PRN code makes a corre- 
sponding bit transition, and transitions to the third 
pulse at the time of the corresponding bit transition 
In the late version of the locally-generated PRN 

> code. 

14. The GNSS receiver of claim 13 wherein tho means 
for selectively enabling the blanked-code correla- 
tions enables an early-mlnus-late correlator at tho 

» time the earliest version of ihe locally-generated 
PRN code makes a bit transition and disables the 
correlators at ine time the later version of the locally- 
generated PRN code makes a corresponding bit 
transition. 

! 

1 5. A PRN codo tracking system for tracking a remotely 
generated PRN code, the system including: 

A. PRN code generation means for generating 
a local PRN code; 

B blankod-PRN code gonoration means for 
producing a blankod-PRN code that has pulses 
lhat precede and follow bit transitions In tho lo- 
cal PRN codo; 

C. correlation means for making correlation 
measurements using the blanked-PRN code, 
the correlation means makfrig the correlation 
measurements at times that correspond to the 
puteee in the blanked-PRN code; and 

D. code synchronization means for directing 
ihe PRN code generation means to align the 
local PRN code with the remotely generated 
PRN code, the codo synchronization means 
using the correlation measurements produced 
by ihe correlation means. 

16. The PRN code tracking system of claim 15 wherein 
the blanked-PRN code generation moans enables 
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the correlation means to make correlation measure- 
ments at the times that correspond to the pulses in 
the blanked-PRN code and disables the correlation 
means otherwise. 

1 7. The PRN code tracking system of claim 1 5 wherein 
the blanked-PRN code produced by the blanked- 
PRN code generation means is zero in between the 
pulse6. 

18. The PRN code tracking system of claim 15 wherein 



fraining from making oarly-minus-late correla- 
tion measurements at other times. 



a. the blanked-PRN code gonoration means 
further produces an oarly-minue-late blanked- 
PRN code, and ?s 

b. the correlation means produces correlation 
measurement using the early-minus-lale 
blanked-PRN code. 



19. A method for tracking a PRN code In a GNSS sat- 20 
elllte signal, the mothod including the steps ol; 

A. generating a local PRN code; 

B. aligning the local PRN code to the PRN coda 

in the GNSS satellite signal by making correla- SB 
tion measurements using the local PRN code; 

C. producing a blanked-PRN code from the kv 
cal PRN code; and 

D. further aligning the local PRN code to the 
PRN codo in the satellite signal using the 30 
blanked-PRN code to make the correlation 
measurements. 



20. The method of claim 1 9 wherein 



a. the slep of producing the blanked-PRN code 
includes producing a codo that has pulses that 
precede and follow bit transitions in Ihe local 
PRN code; and 

b. the step of more closely aligning tho local 
PRN code to the PRN code In tho satellito sig- 
nal includes making correlation measurements 
at the limes of the pulses in the blankod-PRN 
code and refraining from making correlation 
measurements at other times. 



21. The method of claim 20 wherein 



c. the slep of producing the blanked-PRN code 
further includes producing an early-minus-late so 
blanked-PRN code that hae pulses that pre- 
cede and follow bit transitions in tho local PRN 
code; and 

b. the step ol further aligning the local PRN 
code to the PRN code in the satellite signal in- ss 
eludes making early-minus-lale correlation 
measurements at the times of the pulses in the 
early-minus-laio blanked-PRN code and re- 
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ACQUIRE SATELLITE SIGNAL 



USE NARROW CORRELATOR 
CORRELATION MEASUREMENTS 
TO ALIGN THE LOCAL AND 
THE SATELLITE PRN CODES 



USE PUNCTUAL PRN CODE 
CORRELATION MEASUREMENTS 
TO ALIGN THE LOCAL AND 
SATELLITE CARRIERS 



GO TO STEP 
608 



TRACK SATELLITE SIGNAL 
USING NARROW CORRELATORS 




USE THE BLANKED-PRN 
CODE TO MAKE CORRELATION 
MEASUREMENTS 



USE THE BLANKED-PRN 
CODE DLL ERROR SIGNAL TO 
ALIGN THE LOCAL PRN CODE 
TO THE SATELLITE CODE 



USE THE BLANKED-PRN 
CODE PUNCTUAL MEASUREMENTS 
TO ALIGN THE LOCAL CARRIER 
WITH THE SATELLITE CARRIER 



Rnft _ DETERMINE PSEUDORANGES 
BASED ON PRN CODE TIMING 
AND CALCULATED CARRIER 
ANGLE AND PHASE ERROR 
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